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REMOTE CONTROL OF AN ELECTRONIC DEVICE THROUGH DOWNLOADING 
OF CONTROL INFORMATION IN A MOBILE STATION 

The present invention relates to a wireless communication system with a 
number of controllable electronic devices and a mobile station for remotely controlling such 
electronic devices through a short-range wireless communication link such a radio link, an 
infra-red link, or any other suitable wireless link. The mobile station can be dedicated to such 
5 remote control functionality or can be multifunctional device combining remote control 
functionality and other functionality such as cellular or cordless functionality, or the like. 

The present invention further relates to a method of remotely controlling a 
controllable electronic device, to a mobile station and to a controllable electronic device in 
such a system. 

10 

In the PCT Application WO 98/49818 a mobile station is disclosed with 
combined mobile telephony and remote control terminal functionalities. The mobile station 
can act as a remote control unit for a variety of peripheral devices accessible through some 

1 5 type of local area communication system or related communication system. The peripheral 
devices are remotely actuatable in response to a set of predetermined control commands. A 
control command module within the mobile station generates the variety of control 
commands to which the peripheral devices are responsive. The control commands are 
transmitted to the peripheral device via a wireless communication link that is set up between 

20 the peripheral device and the control command module. Local interfaces that apply a single 
communication protocol are included in electronic communication devices otherwise 
connected to an external communication network. Through the single communication 
protocol each of the local interfaces is capable of effecting wireless communication with the 
other local interface modules. In Fig. 4 of WO 98/49818, a local area communication system 

25 is shown with local communication links between a mobile radio station, and, through local 
interface modules, a variety of peripheral devices such as hands-free headsets, television sets, 
radio sets, VCRs, etceteras. Through the local interface modules the peripheral devices can 
also communicate with each other. A user of the mobile radio station enters control 
commands through a user interface of the mobile station. A command control module 
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comprised in the mobile station processes the control commands. A variety of command 
formats may be used to control the peripheral device through some types of command 
module. Either standard wireless communication protocols or a propriety protocol, on a 
single local communication medium may be used. The local interface modules may be 
5 integrated in the housing of the mobile station or may be disposed in a separate housing such 
that it forms a plugable unit. 

In the US Patent 5,636,21 1 a universal multimedia access device is disclosed. 
The universal multimedia device accesses a predetermined one of a number of multimedia 
applications using an appropriate Application Specific (AS)-module interfaced thereto. A 
10 multimedia network delivers diverse multimedia applications such as high-speed data access 
(Internet), phone service, energy management, home security, and video. A transceiver 
operates to transmit and receive RF signals associated with a predetermined one of the 
multimedia applications specified by the AS-module. The MM-device further comprises a 
processing unit in communication with the transceiver and the AS-module. The processor 
15 identifies the AS-module interfaced to the MM-device and determines the predetermined 
MM-application associated with the AS-module. The processing unit then commands the 
transceiver to communicate with the MM-network in a mode associated with the MM- 
application. The AS-module includes a corresponding AS-transceiver for communicating 
multimedia information with an application device coupled thereto. This multimedia 
20 information can include video signals, data signals, voice signals, and control signals. In an 
embodiment, the AS-module enables the universal MM-device to communicate analog or 
digital control signals between the MM-network and an application device such as a home 
control device or an energy control device. A suitable connector is included in the AS- 
module to facilitate connection with a control application device. The universal MM-access 
25 apparatuses are thus built as a common architectural implementation based on a multimedia 
access engine providing a MM-application programming interface to diverse applications, 
while employing an access method to gain access to/from the MM-network. Each AS-module 
has an interface for removable "plug-and-play" installation in the universal MM-access 
apparatus, and a further interface for connecting and disconnecting appropriate application 
30 devices. The processing unit is comprised of a microprocessor that is operative to provide a 
programmable platform for the apparatus. The transceiver is tunable over a range of 
frequencies within a predetermined frequency spectrum of which portions are assignable to a 
variety of multimedia applications. Upon powering up, the processing unit identifies the 
application from an identification signal received from the AS-module. Next, the processing 
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unit commands the transceiver into a predefined mode required by the previously identified 
application. A control AS-module interfaced to a MM-device may include a variety of 
control transceivers. A variety of wireless platforms may be utilized in the transceiver of the 
MM-device. The wireless transceivers can utilize frequency reuse. 
5 Both in the PCT Application WO 98/49818 and in the US Patent 5,636,21 1, 

specific plugable interface modules need to be provided to interface a particular controllable 
electronic device to a device for controlling the electronic device, the controllable electronic 
devices having specific control interface with specific control commands. Once provided 
with a specific controllable interface module, the controllable electronic device can be 
10 controlled by configuring the controlling device accordingly, or by selecting a suitable set of 
control commands in the controlling device. Providing specific interface modules renders a 
system with many different controllable electronic devices complicated, inflexible, and 
expensive. In addition thereto, a universal control device becomes complicated and will 
require a large storage capacity to store a large number of different sets of control commands. 
15 In the Japanese Abstract 09 153 952, a mobile terminal is disclosed to 

remotely control an electric appliance by using a mobile terminal call number. The user dials 
a control code to remotely control a switch of a lighting fixture, or the like. In a radio 
message, the control code is transmitted to a controller controlling electric appliances. The 
dialed controller checks whether the received control code is present in a lookup table. If so, 
20 the lighting fixture is switched on. . r*- 

In the Microsoft ® handbook, "MCSE: TCP/IP Study Guide", Sybex, 1997, 
pages 3, 16-24, and 421, basic principles are disclosed as to TCP/IP Protocols, and browsing 
through the Internet. As defined on page 3, a TCP/IP protocol suite is a Transmission 
Control/Internet Protocol set that an application can use to package its information for 
25 sending across a link. On pages 16-17, a physical data flow and a logical data flow are shown 
on a physical channel between system entities, basically in terms of the well-known OSI 
(Open System Interconnection) Reference model of layers, the OSI reference model 
distinguishing seven layers, a physical layer, a data link layer, a network layer, a transport 
layer, a session layer, a presentation layer, and an application layer. Depending on a 
30 particular application several layers may be combined to a single layer. In accordance with 
the OSI reference model, the physical data flow between system entities occurs through all 
layers between the entities, whereas the logical data' flow is defined as a peer to peer 
communication between corresponding layers of the entities. As defined on page 421, a 
Uniform Resource Locator, a URL, is the standard naming convention on the Internet, a 
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browser is tool for navigating and accessing information on the Internet, usually in the form 
of Web pages hosted by a server, an HTTP, HyperText Transport Protocol, is a protocol 
specification used by the browser to send requests and by the server to respond to the 
requests, and HTML, Hyper Text Markup Language, is the document standard for Internet 
Web pages. - 

In the Bluetooth Specification, "Specification of the Bluetooth System - Core", 
vl.OA, July 26th, 1999, pp. 41-45, 191, 249, 325, 328-330, 335-336, 342-347, 387, and 504- 
513, WAP, Wireless Access Protocol, in the Bluetooth Piconet is disclosed, and a general 
description of the Bluetooth system as related to WAP. In WAP communications, a client 
device communicates with a server device using the WAP protocols. A communication can 
be initiated by a client or by a server device. Upon initiation, a so-called Bluetooth Service 
Discovery Protocol is started to find the other one of the client/server pair. Client addressing 
is mainly done through Uniform Resource Locators, URLs, as used with Internet browsers. 
URLs are text strings that describe the document that is accessed. On page 508, a WAP 
Protocol Stack is shown, entities of the protocol stack further being defined on said pages 41- 
45, 191, 249,-325, 328-330, 335-336, 342-347, 387. On page 41, a general description of BT, 
Bluetooth, a short-range radio link, is given. On page 42, a BT piconet with masters and 
slaves is shown. On pages 43-45, the BT physical channel, with time slots, is shown. Page 45 
describes types of links between masters and slaves, a master being a link initiator, and a 
slave being the device accessed by the master. Pages 191; 249; 325, 328-330, 335-336, 342- 
347; and 387 describe LMP messages; the L2CAP; the Service Discovery Protocol; and the 
RFCOMM protocol; respectively. 

It is an object of the invention to provide a simple and flexible remote control 
device for controlling many different types of controllable electronic devices. 

It is another object of the invention to provide a simple, intuitive user interface 
in such a remote control device. 

It is still another object of the invention to provide a learning mechanism for 
such a remote control device such that a remote control device coming out of range of a 
particular controllable electronic device and in-range thereof thereafter still recognizes such a 
controllable electronic device. 

In accordance with the invention, a wireless communication system is 
provided comprising a plurality of controllable electronic devices and a mobile station for 
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communicating with one of said controllable electronic devices through a short-range 
wireless communication link, said mobile station composing a display screen, a user input 
interface, and an access protocol browser operating in accordance with an access protocol, a 
method of remotely controlling said one controllable electronic device, said method 
comprising: 

through said short-range wireless communication link, said mobile station 
requesting said controllable electronic device to download data representative of a control 
interface associated with said one controllable electronic device; 

downloading of said data in a data format interpretable by said access protocol 

browser; and 

displaying on said display screen of said data as control interface menu pages 
representative of said control interface, said access protocol browser navigating through said 

control interface menu pages. 

Preferably, the mobile station checks whether the one controllable electronic 
device has access control capability before requesting the controllable electronic device to 
download its control interface. Herewith, it is prevented that the mobile station unnecessarily 
accesses electronic devices not supporting downloading of a control interface. 

Preferably, a mobile station reuses a downloaded control interface if, after 
having come out of range of a particular controllable electronic device comes in-range of the 
same controllable electronic device thereafter. 

Preferably, the access protocol is a markup language reading and interpretation 
protocol and the data represent a markup language, such a WAP Protocol, and a WAP 
markup language as defined in said Bluetooth Standard. Such a browser is simple and easy to 
operate and requires a reduced storage capacity and a small display unit. This is of particular 
interest when incorporating the browser in a mobile station also incorporating telephony 
functionality such as cordless or cellular telephony functionality. Simple and low storage 
requiring methods do not unnecessarily exhaust a battery comprised in the mobile station. 
When implementing the remote control functionality in a device such as a laptop with a 
larger display unit, a more complex browser could be used, together with a more complex 
) markup language such as HTML. 



Figure 1 shows a wireless communication system with a number of 
controllable electronic devices and a mobile station. 
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Figure 2 shows a functional block diagram of a mobile station in accordance 

with the present invention. 

Figure 3 shows a front view of a mobile station. 

Figure 4 shows a functional block diagram of a first controllable electronic 
device according to the invention. 

Figure 5 shows a functional block diagram of a second controllable electronic 

device according to the invention. 

Figure 6 shows basic operation of the mobile station as a remote control 

device. 

Figure 7 shows six menu pages that are downloaded from a server. 
Figure 8 shows a file referred to by the URL tv/index.wml. 
Figure 9 shows a file run on the server. 

Figure 10 shows a first request of the client, and a response from the server, in 

HTTP-format. 

Figure 11 shows posting by the client 70 to the server 71, in HTTP-format. 
Throughout the figures the same reference numerals are used for the same features. 



Fig. 1 shows a wireless communication system 1 with a number of 
controllable electronic devices 2, 3, and 4, and a mobile station 5. Shown is the mobile 
station 5 communicating with the controllable electronic device 2 through a short-range 
wireless communication link 6. In addition to communication with the controllable electronic 
device 2, the mobile station can be configured to communicate with a wireless network 7 
such as a cellular or cordless telephony and/or data network. The mobile station 5 can also be 
configured to only communicate with the devices 2, 3, and 4. Then, the mobile station's 5 
main functionality is a universal remote control terminal in accordance with the present 
invention. The wireless network 7 may be coupled to a public switched telephony network 8. 
The mobile radio station 5 in its capacity to communicate with the devices 2, 3, and 4, forms 
a local network 9 with the devices 2, 3, and 4. Preferably, the local network 9 is a network in 
accordance with said Bluetooth Specification. The short-range wireless communication link 6 
can be a radio link, an infrared link, or any other suitable wireless link. The mobile station 5 
may be configured to support both a short-range radio and a short-range infra-red link so as 
to communicate with controllable electronic devices capable of transmitting through only a 
radio link or only an infra-red link. 
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R. ' shows a functional block diagram of the mobile station 5 in accordance 
with the present invention. The mobile station 5 comprises a ce.lu.ar radio transceiver 20, a . 
B.ue.oo.h (BT) radio transceiver 21, and a BT infrared transceiver 22 w,th a Ugh, Emithng 
Diode (LED) 23 for transmimng and receiving modulated infrared signals. The transceivers 
20 -1 and n compnse recetve and transmit Circuitry, tncluding nuxers, modulators, 
demodulators, analog-to-digita, conveners, and digital.o-analog conveners so that the 
tra nsce,vers transmit digital signals generated by processing means 24 and prov.de digita 
sjg na.s to the processing means 24. Such transceiver crcuitry is well known and ,s not shown 
,„ detail here. The BT transceivers 2. and 22 are configured to operate in accordance w„h 
) said Bluetooth Specification. The mobile station. 5 father comprises a random access 

memory (RAM) 25 for stonng volatile data w,th a memory pan 25A for stonng non-vola„le 
data a ROM-memory 26 comprising a wireless access protocol browser 27, a display 28, and 
a user input interface 29, the RAM 25, the ROM 26, the display 28, and the user ,npu, 
interface 29 bemg coupled to the processing means 24. The transceivers 20, 21, and 22 
5 respectivelycomprise received signal strength measurement means 20A, 2.A and 2A^ 
F,g 3 shows a front view of the mobile station 5. Shown are the display 28, 
and the user input interface 29 comprising a keypad 30, a cursor control means 3. including 
up, down, left, andr^tcontro, arrows 32, 33. 34, and 35, a left soft-key 36, a ngh, soffkey 
37 and dedicated functton keys 38, 39, and 40. The dedicated function key 38 can be used to 
20 invoke the remote control functionality of the mobile station 5. The dedicated function keys 
39 and 40 can be assigned to invoke control of often used devices, such as a TV set or a 
Stereo apparatus. Alternative*, the remote control functionality can be invoked by 
s.mu,taneous,yacma,,ng,woordinarykeysof,hekeypad30,suchaa,he and # keys. 
When t hemobi.es,auon5,sadedic,«dr=mo tt con ff o.device,.heremo.eco„ TO 
25 functional can be invoked automatically through Bluetooth mechanisms when the station 
is in-range of a controllable electronic device. 

Fig 4 shows a functional b.ock diagram of the controllab.e electronic device 2 
according ,0 the present invention. The controllab.e electronic dev.ee 2 is a television se, 
with TV crcuitry 50 coupled ,0 a TV screen 51, and with a TV antenna 52 
30 means 53 The TV se. 2 funher comprises a„ infra-red transce.ver 54 with a LED 55, a ROM 
71 a RAM 57 including a „on-vola t „e RAM 58, the rR-,ransce,ver 54, the ROM 56. and 
t „e RAM 57 being coupled to the processing means 53, As far as implementing the features 
according to the present invention, the DUransceiver 55 and the processing means 53 op rate 
i„ accordance with sa,d Bluetooth Specification modified to use infrared. The non-vola.i.e 
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RAM 58 is intended to store control settings of the television set 2 such as selected channel, 
volume, brightness, contrast, and color. To this end the non-volatile RAM 58 has storage 
locations for storing these control settings, the TV set being controlled in accordance with 
current settings. 

Fig. 5 shows a functional block diagram of the controllable electronic device 3 
according to the present invention. The controllable electronic device 2 is a tuner, amplifier, 
and compact disk player combination comprising tuner and amplifier and CD circuitry 60 
coupled to a radio antenna 61. The circuitry 60 is coupled to processing means 62. The 
combination 3 further a BT-transceiver 63 coupled to a BT-antenna 64, a ROM 65, and a 
RAM 66 including a non-volafile RAM 67, the BT-transceiver 63, the ROM 65, and the 
RAM 66 being coupled to the processing means 62. As far as implementing the features 
according to the present invention, the BT-transceiver 63 and the processing means 62 
operate in accordance with said Bluetooth Specification. The non-volatile RAM 67 is 
intended to store control settings of the combination 3 such as selected channel, volume, 
bass, treble, play, stop, pause, fast forward, etceteras. To this end the non-volatile RAM 67 
has storage locations for storing these control settings, the combination being controlled in 
accordance with current settings. 

The controllable electronic devices according to the present invention include 
all kinds of devices such as the shown TV set 2 and the shown combination 3, and also, but 
not limitative, a domestic appliances such as a microwave oven, or any other controllable 
device implementing the features according to the present invention. 

Fig. 6 shows' basic operation of the mobile station 5 as a remote control 
device. Block 70 shows the mobile station 5 as Wireless Access Protocol (WAP) client and 
block 71 shows the controllable electronic device 3, that is a TV set, as a WAP server. In 
terms of WAP, the TV set 3 and the mobile station 5 form a server/client relationship. In 
terms of Bluetooth, depending on the device initiating a Bluetooth link, either the server or 
the client is a master, the other one of the server/client then being a slave. In the server/client 
relationship, the client sends requests to the server, and the server responds to such requests. 
WAP is used by the mobile station 5 to control the controllable electronic devices 2, 3, and 4. 
During Bluetooth link setup between the mobile station 5 and a controllable electronic 
device, a Bluetooth Service Discovery Protocol is started as defined on pages 328-330, 335- 
336, 342-347 of said Bluetooth Core. First it is checked whether the controllable electronic 
device has WAP capability. If so, the server is requested to provide details of the WAP 
service in the form of service attributes as defined on page 330 of said Bluetooth Core, an 
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essential attribute bemg a home page URL 72 refemng to a file with remote contro. menu 
pages the URL tv/.ndex.wml. As defined on page 330 of said Bluetooth Core, a serv,ce 
record in the server 71 con.am.ng me attributes is unique .0 m.s particular server through a 
so called service record handle, a 32-bi. ,dent,fica..o„ number mat uniquely .denhfies a 
service record withm .he server 7 1 . Each handle is unique only - each SDP server. The 
handle used to reference the service on me server71 w,l. be meaningless if presen.ed .o 
a„o,her server. Upon l.nk setup and service discovery, .he mobile s.a.,o„ 5 au.oma.,cally 
opens ,he browser 27, and, using theURLorlext suing ,,/index.wml. reques-s the server 71 
,„ download me file to wh,ch ,v/,ndex.wml refers in .he server 71. The WAP browser 27 „ 
used to nav,ga,e .he downloaded menu pages. When more menu pages or o.her mformahon 
are/is needed, me mobile station 5 revests the s=™ 71 ,0 provide such pages or 
information. The downloaded file contains a firs, small screen display card .ha, contains an 
initiation message such as "Philips TV REMOTE CONTROL", and current settings of the 
TV set 2 Tins card is only drsplayed on me mobile station for a short period of time, e.g., 1 
second Then, the WAP browser 27 moves .0 tine next card, the next card bemg displayed on 
,he display 28. Commands se.ec.ed on .he menu pages, such as a desired volume control 
setting « sent .o the server 71 tn the form of requests. The server 7, in.erpre«s such requests 
and acs accordingly, in tine example given by updating a volume control memory Nation m 
.he memory 58 setting the volume of the TV set 2, and responds .o such requests by 
, confirming the action u*en. In case,.af,er hnk setup and downloading of .he file peered to 
by ,v,index.wml, the mobile station 5 gets ou.-of-range of .he contiollable electron.c ev.ce ,, 
comrols and .hereafter gets in-range of .he same controllable electronic device, downloading 
0 , ,„e file referred .0 by .v/index.wml can be dispensed with. In .ha. case, me mob,le s.ahon 
5 can retrieve this file from .he memory 25 A where mis file is stored a. downloadmg. In 
5 terms of OS! layers, after sunning up of me browser 27, peer to peer communications occur 
he.ween Application layers of .he mobile s,ation 5 and .he TV se. 2. Other —canons 
occur in lower layers, .he described Service Drscovery Protocol occurring ,n the OS1 Sess,on 
,ayer Phys.caUy, all data between the mobile station 5 and the TV se. 2 are exchanged 
through a bearer service. Information is exchanged through packets, e.g., using a sena. port 
S0 profile or a more complex o bj ec. exchange profile as defined in tine Bluetooth Specification. 

When the Service Kscovery Pro.ocol d.scovers more man one dev,ce, e.g., ,n 
a si.uat.on where ,wo WAP capable BT-devices are placed in close proximi.y wi.h each 
o,her, such a dev.ce conflict can be solved in several ways. In a sem—ic me. od ,o 
selec. a desired contiollable elecronic device, after .he Serv,ce D.scovery Pro.ocol found, 
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e.g., two devices such as the devices 2 and 3, the user of the mobile station 5 is offered a 
choice to manually select one of the devices 2 and 3 that should be controlled. After such a 
manual selection, the index-file of the selected device is downloaded. Another method to 
select one of the devices makes use of the BT-capability that a device can remember BT- 
links. In a situation that, when in-range, the mobile station 5 finds two controllable electronic 
devices, it stores the BT-links of these two devices in the memory 58. When coming into 
range of these two devices again, after first having been out-of-range of these two devices, 
the user configures the mobile station 5 of which stored BT-link the index file should be 
downloaded, and thus which controllable electronic device should be controlled. Also, after 
the Service Discovery Protocol discovered multiple in-range controllable electronic devices, 
multiple sets of cards for the discovered controllable electronic devices may be downloaded. 
In this embodiment, the identification numbers and URLs of the discovered electronic 
devices are stored into the memory 25 A. Then, browser 27 can open multiple windows for 
such controllable electronic devices so that the user can select to control any one of the 
discovered controllable electronic devices. 

Fig. 7 shows 6 menu pages 80, 81, 82, 83, 84, and 85 that are downloaded 
from the server 71 and that are displayed on the display 28 of the mobile station 5. The menu 
pages 80-85 is an example of the client application using WML (WAP Markup Language) 
interpreted by the WAP browser 27. The six menu pages or cards 80-85 allow a user of the 
mobile station 5 to navigate six screens. The screens 80-85 are defined as follows: 
Screen 80: "Function Select: 

[Volume] 
[Channel] 
[Settings] 

OK Menu" 
Screen 81: "Volume Level 

1 Mute 
2 

■3* . 

4 Medium 

5 

6 



High 



Set Menu" 
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Screen 82: 



'-'Channel 


1 


Cable Index 


2 


Fox 2 


3 • 


MSWBC 


4 


CNN 


5 


ABC 


6 


PBC 


7 


ESPN 


Set 





PCT/EP00/08443 

11 



10 Screen 83: "[Brightness] 

[Contrast} 



Menu" 



15 



20 



25 



30 



Brightness Menu" 
Screen 84: "Contrast Level 

1 Low 
2 
3 

4 Medium 

5 • 

6 

7 High 
Set Menu" 
Screen 85: "Brightness Level 

1 Low 
2 

3 • 

4 Medium 
5 

6 

7 High 

Set • ' Menu" 

The screen 80 is the first browser screen after the initial display of the 
controllable electron* dev,ce identification message that is delayed only once. The up and 
down arrows 32 and 33 are used to scroll up and down the screen 80 if needed, and to pent 



WO 01/20572 PCT/EP00/08443 

12 

to a desired menu item. The left soft key 36 corresponds to the labels projected above this 
key, such as "OK", "Set", and "Brightness". The right soft key 37 corresponds to the label 
"Menu" projected above this key. When operating on the screen 80, the user points to 
[Channel] and confirms this choice by actuating the left soft key 36. Then, the screen 82 is 
displayed where the user can select the desired channel. Accordingly, volume, contrast, and 
brightness settings can be chosen. The selected command or control parameter, such as set 
volume to setting "3", is conveyed to the TV set in the form of a request, as described before. 
The downloaded data may represent all control interface menu pages of the TV set 2. 
Alternatively, upon initial downloading, only a part of the control interface menu pages may 
be downloaded, further pages being downloaded on request from the client. The initial 
settings of the TV set may alternatively be requested from the server 71 after downloading of 
the menu page file. In order to prevent that the browser 27 retrieves previously stored pages 
rather than requesting new pages, when such new pages are required, the usual browser cache 
mechanism is disabled. 

Fig. 8 shows a file 90, index. wml, referred to by the URL tv/index.wml. The 
file 90 contains the menu pages WAP ML, and initial information conveyed to the client 70. 
The content of the file 90 is as follows. Text in Italic represents comments not actually 
present in the file 90, explaining the meaning of several parts of the file 90. 
"Required header information 
<?xml version="1.0"?> 

<!DOCTYPE wml PUBLIC " -//W APFORUM/DTD WML 1.1//EN" 

http://www.wapforum.ore/DTD/wml l.l.xml > 

<wml> 

Set up cache control for proper interaction with the server 
<head> 

<meta http-equiv="Cache -Control" content="max-age=17> 

<head> 

Cause the word 'Menu' to appear above the right soft key 37 in each card 
<template> 

<do type= M options" label-"Menu"> 
<go href="#Home"/> 

<do> 

</template> 
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Create Initialization card. This is displayed for 1 second prior to Card 1 being displayed. It 
also initializes the various control settings. 
<card title="First"> 

<onevent type="ontimer"> 
5 • <go href="#Home"> 

<setvar name="vor value="27> 
<setvar name= ,, chan" value= M 37> 
<setvar name="bright" value="47> 
<setvar name="cont n value="37> 

10 </go> 
</onevent> 
<timer value="107> 
<p> 

Philips TV<br/>REMOTE CONTROL 

15 </p> 
</card> 

Create card 1. Selecting one of the options causes card 2, 3, or 4 to be displayed 
<card title="Main" id= M Home"> 
' <P> 

20 Function Select:<br/> 

<anchor title= ,, Volume"> 

<go href="#volume"/> Volume 
</anchor><br/> 
<anchor title= ,, Channel M > 
25 <go href="#channel7> Channel 

</anchorxbr/> 
<anchor title="Settings n > 

<go href="#settings"/> Settings 
</anchorxbr/> 
30 </p> 
</card> 

Create card 4. Selecting one of the options causes card 5 or 6 to be displayed 
<card title= M Settings n id="settings M > 

<do type= M accept u label= ,M, > 
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<go href= ,, #Home7> 

</do> 
<P> 

<anchor tile="Brightness"> 

<go href="#bright7> Brightness 
</anchor><br/> 
<anchor title="Contrast"> 

<go href="#contrast7> Contrast 
</anchorxbr/> 
</p> 

</card> 

Create card 2. Selecting one of the options causes a variable called "Volume' to be posted to 
the server 71. The actions of the server 71 are simplified in a Perl script called 
remoteaction.cgi 

<card title=" volume" id="volume"> 

<do type=" accept" label="Set"> 

<go href="remoteaction.cgi"> 

<postfield name= H Volume" value="$vorV> 

</go> 

</do> , 
<p align="center"> 
Volume Level $vol 

<select name="vol" > 

<option value=" 1 " >Mute</option> 

<option value="2" ></option> 

<option value="3" ></option> 

<option value="4" >Medium</option> 

<option value= M 5" ></option> 

<option value="6 M ></option> 
<option value="7" >Maximum</option> 
</select> 

</p> 

</card> 
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Create card 5. Selecton of the options causesa variable called 'contrast' to be posted to the 
server 7 1 . 

<card title="contrast" id="contrast"> 

<do type="accept" label="Set"> 
5 <go href="remoteaction.cgi"> 

<postfield name="contrast" value="$cont7> 

</go> 

</do> 

<p align="center"> 
10 Contrast Level Scont 

<select name="cont" > 

<option value="l" >Low</option> 
<option value="2" ></option> 
<option value="3" ></option> 
<option value="4" >Medium</option> 

<option value="5" x/option> 

<option value="6" x/option> 
<option value="7" >High</option> 

</select> 

20 ^ 

Create card 6. Se.ec.ing one of the options causes a variab.e called 'bnghtness' to be posted ,0 
the server 71. 

<card title="bright" id="bright"> 
25 <do type="accept" label="Set"> 

<go href="remoteaction.cgi"> 

<postfield name="brightness" value="$brighf7> 

</go> 

</do> 

30 <p align="center"> 

Brightness Level Sbright 

<select name="bright" > - 

<option Value="l" >Low</option> 

<option value=' , 2" ></option> 
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<option value="3" ></option> 
<option value="4 M >Medium</option> 

<option value="5" ></option> 

<option value="6" ></option> 
<option value="7" >High</option> 
</select> 

</p> 

</card> 

Create card 3. Selecting one of the options causes a variable called 'channel' to be posted to 
the server 71. 

<card title="Channer id= M channer> . 

<do type="aceept M .label="Set"> 

<go href="remoteaction.cgi n > 

<postfield name="channel n value="$chan7> 

</go> 

</do> 

<p align="center n > 
Channel $chan^ 

<select name= ,, chan n > 

<option value='T' >Cable Index</option> 
<option value= ,, 2 n >Fox 2</option> 
<option value= M 3 M >MSNBC</option> 
<option value= H 4" >CNN</option> 
<option value= ,, 5" >ABC</option> 

<option value= M 6 n >PBC</option> 
<option value="7" >ESPN</option> 
</select> 

</p> 

</card> 
</wmI>" 
End-of-file 90. 

For bigger screens, instead of WML, HTML may be used. 
Whenever a value is posted in cards 2, 3, 5, or 6, the file , remoteaction.cgi* is 
called. The file Yemoteaction.cgi' is a program that runs on the server 71, and that is stored in 
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the memory 56. This program interprets values posted by the client 70 and takes a proper 
control action in the TV set 2, and, thereafter, sends a new card to the client 70 to confirm the 
action. The new card instructs the client 70 to return to the previous card. 

Fig. 9 shows a file 100, 'remoteaction.cgi", used by a Perl Script Interpreter 
5 run on the server 71. The contents of the file 100 is as follows. 
"This is a Perl script 
#!/usr/local/bin/perl 

#This script emulates the functionality of the TV Server with 
#Volume, Channel, Brightness and Contrast Control 
10 For simplicity, reasons, only one variable is set - the location where data is to be stored. In a 
real implementation, memory locations in the memory 58 are defined for the control 

parameters, 
i ) tii/ 

7T ff it 

# Set Variables 

15 # In this emulation a file is written to. In an actual 

# implementation, memory locations in the memory 58 are addressed 
$logpath = "wmltest.txt"; 

# 

1 1 JIM 

tt a a 
20 tffftt 

This part of the code extracts the data that was sent. For example if Volume = 3 was sent this 
is put into the variable FORM as a pair such that $FORM{ 'Volume'} = 3 

n ii ii 

TrffW 

# Get form data 

25 # The following script interprets the commands posted by the client 
This mechanism allows more than one variable to be sent at a time . 

# (remote control) 

read (STDIN, $buffer, $ENV { 'CONTENT_LENGTH' } ); 
©pairs = split(/&/, Sbuffer); 
30 foreach $pair (©pairs) 

{ 

($name, $value) = split(/=A Spair);- 

# Un-Webify plus signs and %-encoding 

$value =- tr/+/ /; 
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Svalue =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C", hex($l))/eg; 
$FORM{ $name } = Svalue; 

} 

# Form data obtained 

5 # The variable FORM now has control data 

This part of the code acts on the data. In this example the data is written to a file, but in a real 
implementation values are written to memory locations and change TV settings. 

10 # In this emulation the data wil be recored in a data file 
open (LOG, "»$logpath"); 

foreach $key (keys(%FORM)) {print LOG "$key = $FORM{$key)\n;} 

close(LOG) 

# 

1 5 // // // 

This last part of the script sends a new card to the client 

i> ii ft 
tt a a 

# Now the client needs to be instructed what to do 
print "Content-Type: text/vnd.wap.wml\n\n; 

20 print «EndWML; 

The Cache-Control is very important as it forces the client 70 to request a new card from the 
server 71. 

<?xml version= M 1.0"?> 

<!DOCTYPE wml PUBLIC "-/AVAPFORUM//DTD 1.1//EN" 
25 http://www.wapforum.org/DTD/wml 1 . 1 .xml "> 

<!-- Main menu for WML examples --> 
<wml> 

This card is a simple instruction to return to the previous card. 
<head> 

30 <meta http-equiv= n Cache-Contror content= M max-age=0/> 

</head> 

<card title=" Action" id="Home"> 
<onevent type="onenterforward n > 
<prev/> 
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</onevent> 

<p> 

Control Set 

</p> 

</card> 

</wml> 
EndWML 



10 



End-of-file-100. , Q , flle to the client a very flexxble systexn is obt^ned 

Because the server sends a file to the client, d vc y 

fM sending a simple or an advanced con.ro. interface to the client. ..e., by using a -P 
;i g :i g e,L m a n u f ac Mr e r o f *eTV 5 e t2 Ua 1 ,owed t o< ie «n ete owncon lro ,,n 1 e rf acea„d 

,o easily download such a control interface to the remote control dev.ee. 

Fig. iOshowsaf.rs.rcuestof.hecUen.TO.andaresponsefromU.eserver 

15 71, in HTTP-format. 

First request of client, in HTTP-format: 

"OFT brt p-//tv/index.wml Hi TP/1-1" 

Response by server, in HTTP-format: 

"CONTENT_TYPE=Text/wml 
20 cONTENT_LENGTH=file length of the included file 

The file index.wml stored in the memory 56" 
' Fig. U shows P ostin g bythedient70tothe S erver71,inHTTP-fonna, 

Posting to the server 7 1, in HTTP-format: 

••POST htt rW/tv/rem oteaction.cgi HTTP/1. 1 
25 CONTEN T_TYPE=application/x-www-form-urlencoded 

CONTENT_LENGTH=9 
channel=2" 

In this example, the channel selection for channel two is posted. 

ta vtew of the foregoing ,, w„, he evident to a person skilled in the an that 
30 various modtfications tnay be made within the spirit and the scope of the invention as 

examples provided. The word "comprising" does not exclude the presence 
or steps than those listed in a claim. 
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CLAIMS: 



1. In a wireless communication system (1) comprising a plurality of controllable 
electronic devices (2, 3, 4) and a mobile station (5) for communicating with one of said 
controllable electronic devices (2, 3, 4) through a short-range wireless communication link 
(6), said mobile station (5) comprising a display screen (28), a user input interface (29), and 

5 an access protocol browser (27) operating in accordance with an access protocol, a method of 
remotely controlling said one controllable electronic device (2, 3, 4), said method 
comprising: 

through said short-range wireless communication link (6), said mobile station 
(5) requesting said controllable electronic device (2, 3, 4) to download data representative of 
10 a control interface associated with said one controllable electronic device (2, 3, 4); 

downloading of said data in a data format interpretable by said access protocol 
browser (27); and 

displaying on said display screen (28) of said data as control interface menu 
pages (80, 81, 81=2, 83, 84, 85) representative of said control interface, said access protocol 
15 browser (27) navigating through said control interface menu pages (80, 81, 82, 83, 84, 85). 

2. A method as claimed in Claim 1, comprising, prior to said requesting, 
checking whether said one controllable electronic device (2, 3, 4) has access protocol 
capability. 

20 

3. A method as claimed in Claim 1, comprising setting up of said short-range 
wireless communication link (6) if said one controllable electronic device is (2, 3, 4) in-range 
of said mobile station (5). 

25 4. A method as claimed in Claim 1, comprising storing of an identification of 

said controllable electronic device (2, 3, 4) and of said downloaded data, and, upon breaking 
off of said link (6) due to said controllable electronic device (2, 3, 4) becoming out of range, 
verifying during a setting up of a next short-range wireless communication link with a next 
controllable electronic device (2, 3, 4) whether said next controllable electronic device (2, 3, 
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4) is said controllable electronic dev.ce (2, 3, 4) of said broken link, and, if so, reusing said 
stored downloaded data. 

5 . A method as claimed in claim 1, wherein said data represent all control 

interface menu pages (80, 81, 82, 83, 84, 85) of said control interface. 

6 A method as clahned in Claim 1, wherein said data represent a part (80) of all 
control interface menu pages(80, 81, 82, 83, 84,85), said part including a main menu page 
(80). 

7 • A method as claimed in Claim 1, wherein said access protocol is a markup 
language reading and interpretation protocol and said data represent a markup language. 

8 A method as claimed in Claim 7, wherein said markup language reading and 
15 interpretation protocol-is a wireless access protocol and said markup language is a wireless 

access protocol markup language. 

9 . A method as claimed in Claim 7, wherein said markup language is HTML. 

20 10 A method as claimed in Claim 1, wherein a control interface menu page (80, 

81 8? 83, 84, 85) of.said control interface menu pages (80, 81, 82, 83, 84, 85) comprises a 
plurality of selectable control parameters, and, upon selection of one of .aid plurality of 
selectable control parameters, said method comprises transmitting of said one control 
parameter to said one controllable electronic device (2, 3, 4), and, in said one controllable 
electronic device (2, 3, 4) effecting a control action on the basis of said one control 



25 



parameter. 



! 1 A method as claimed in Claim 10, comprising running a markup language 

program at the one controllable electronic device (2, 3, 4), said one control parameter being 
30 transmitted in a data format intertable by said markup language program. 

12 A method as claimed in Claim 1 1 , comprising, from said markup language 

program, transmitting of an instruction to said mobile station (5) to adopt a menu page state 
in accordance with a current control state of said one controllable electronic device (2, 3, 4). 
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13. A method as claimed in Claim 11, wherein said requesting is done through 
transmission of a URL previously received from said one controllable electronic device (2, 3, 
4), said URL identifying a start address of said data in said one controllable electronic device 

5 (2,3,4). 

14. A method as claimed in Claim 13, wherein said short-range wireless 
communication link (6) is a Bluetooth link, and said access protocol is a wireless access 
protocol. 

10 

15. A method as claimed in Claim 3, wherein said data comprises a current control 
state of said controllable electronic device (2, 3, 4). 

16. A wireless communication system (1) comprising: 

15 a plurality of controllable electronic devices (2, 3, 4) with control interfaces 

configured to control said controllable electronic devices (2, 3, 4), and with means for 
downloading (53, 62) data representative of a control interface corresponding to one of said 
controllable electronic devices (2, 3, 4); 

a mobile station (5) for remotely controlling said one controllable electronic device (2, 3, 4) 
20 through a short-range communication link (6), said mobile station (5) comprising display 

means (28), a user input interface (29), and an access protocol browser (27) operating in 

accordance with an access protocol, said mobile station (5) being configured to submit a 

request, through said short-range communication link (6), to said controllable electronic 

device (2, 3, 4) to download said data, 
25 said means for downloading (53, 62) being configured to download said data 

in response to said request, in a format interpretable by said access protocol browser (27), 
said display means (28) being configured to display said downloaded data as 

control interface menu pages (80, 81, 82, 83, 84, 85) representative of said control interface, 

and 

30 said access protocol browser (27) being configured to navigate through said 

control interface menu pages (80, 81, 82, 83, 84, 85) 
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17 A system (1) as claimed in Claim 16, wherein said mobile station (5) 

comprises means to check (24) whether said one controllable electronic device (2, 3, 4) has . 

access protocol capability. 

5 18 A system (1) as darned in Cla,m l6, wherein said access protocol is a markup 

taguage reading and interpretation protocol and said data represent a markup language. 

, 9 A system (1) as claimed in Claim 16. wherein a control interface menu page of 

said control interface menu pages (80, 81. 82. 83, 84, 85) comprises a plurality of selectable 
10 control parameters, through s*d user input interface (29), a user selects one of satd control 
parameters, satd mobile station (5) comprises means for transmitting (21) said one control 
parameter to said one controllable electronic device (2, 3,4), and said controtlable electron, 
dev.ce (2, 3, 4) comprises means for effecting a control action (53. 62, 58, 67) on the basts of 
said one control parameter. 

20 A system (1) as claimed in Claim 19, wherein said mobile station comprises 

means for running a markup language program, said markup language program being 
configured to interpret said control interface menu pages (80, 81, 82, 83, 84, 85). 

20 21 A mobile station (5) for remotely controlling, through a short-range 

communication link (6), of one of a plurality of controllable electronic devices (2, 3.4) 
comprised in a wireless communication system that comprises said mobile station (5), said 
plurality of controllable electronic devices (2, 3, 4) comprising control interfaces configured 
to control said controllable electronic devices (2, 3, 4), and means for downloading (53, 62) 
25 datarepresentativeofacontrolinterfacecorrespondingtooneofsaidcom 

devices (2 3, 4), said mobile station (5) comprising: 

display means (28), a user input interface (29), and an access protocol browser 
(97) operating in accordance with an access protocol, said mobile station (5) being 
configured to submit a request, through said short-range communication link (6), to said one 
30 controllable electronic device (2, 3, 4) to download said data, said access protocol browser 
(27) being configured to interpret downloaded data, said display means (28) being configured 
to display said downloaded data as control interface menu pages (80, 81, 82, 83, 84, 85) 
representative of said control interface, and said access protocol browser (27) being 
configured to navigate through said control interface menu pages (80, 81, 82, 83, 84, 85). 
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22. A mobile station (5) as claimed in claim 21, comprising means to check (24) 

whether said one controllable electronic device has access protocol capability. 

5 23. A mobile station (5) as claimed in Claim 21, wherein said access protocol is a 

markup language reading and interpretation protocol and said data represent a markup 
language. 

24. A mobile station (5) as claimed in Claim 21, wherein a control interface menu 

10 page of said control interface menu pages (80, 81, 82, 83, 84, 85) comprises a plurality of 

selectable control parameters, through said user input interface (29), a user selects one of said 
control parameters, and said mobile station (5) comprises means for transmitting (21) said 
one control parameter to said one controllable electronic device (2, 3, 4), 

15 25. A controllable electronic device (2, 3, 4), that, through a short-range 

communication link (6), is remotely controllable by a mobile station (5) with an access 
protocol browser (27) operating in accordance with an access protocol, said controllable 
electronic device (2, 3, 4) comprising: 

a control interface configured to control said controllable electronic device (2, 

20 3,4); 

means for downloading (53, 62), in response to a request issued by said mobile 
station (5), of data representative of said control interface, in a format interpretable by said 
access protocol browser (27); and 

means for effecting (53, 62, 58, 67), in response to a control parameter that is selected from a 
25 control interface menu page generated by said access protocol browser (27) from said 

downloaded data, and that is received from said access protocol browser (27), of a control 
action in said control interface. 
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